<template>
  <div>
    <el-form>
       <el-form-item label="角色名称">
         <el-input v-model="role.name"></el-input>
       </el-form-item>
       <el-form-item label="角色编码">
         <el-input v-model="role.code"></el-input>
       </el-form-item>
       <el-form-item label="角色描述">
         <el-input type="textarea" v-model="role.description"></el-input>
       </el-form-item>
       <el-form-item>
         <el-button @click="$emit('cancel')">取消</el-button>
         <el-button type="primary" @click="onSubmit">确认</el-button>
       </el-form-item>       
    </el-form>
  </div>
</template>

<script lang="ts">
import Vue from 'vue';
import { createOrUpdate, getRoleById } from '@/services/role';

export default Vue.extend({
  name: 'CreateOrEdit',
  props: {
      roleId: {
        type: [String, Number],
      },
      isEdit: {
        type: Boolean,
        default: false,
      },
  },
  data() {
      return {
        role: {
            code: '',
            name: '',
            description: '',
        },
      };
  },
  created() {
      if (this.isEdit) {
          this.loadRole();
      }
  },
  methods: {
    async loadRole() {
      const { data } = await getRoleById(this.roleId);
      this.role = data.data;
    },

    async onSubmit() {
      await createOrUpdate(this.role);
      this.$message.success('操作成功');
      this.$emit('success');
    },
  },
});
</script>

<style scoped>

</style>